# CSE211 Digital Design

Akdeniz University

Week11: Combinational Logic Part 2

Assoc.Prof.Dr. Taner Danışman tdanisman@akdeniz.edu.tr

| Week 01 | 09/16/2024 Introduction                          |
|---------|--------------------------------------------------|
| Week 02 | 09/23/2024 Digital Systems and Binary Numbers I  |
| Week 03 | 09/30/2024 Digital Systems and Binary Numbers II |
| Week 04 | 10/07/2024 Boolean Algebra and Logic Gates I     |
| Week 05 | 10/14/2024 Boolean Algebra and Logic Gates II    |
| Week 06 | 10/21/2024 Gate Level Minimization               |
| Week 07 | 10/28/2024 Karnaugh Maps                         |
| Week 08 | 11/04/2024 Karnaugh Maps                         |
| Week 09 | 11/11/2024 Midterm                               |
| Week 10 | 11/18/2024 Combinational Logic                   |
| Week 11 | 11/25/2024 Combinational Logic                   |
| Week 12 | 12/02/2024 Timing, delays and hazards            |
| Week 13 | 12/09/2024 Synchronous Sequential Logic          |
| Week 14 | 12/16/2024 Synchronous Sequential Logic          |

# Binary Multiplier

3

 $C_3$ 





4

- For J multiplier bits and K multiplicand bits, we need
  - (J×K) AND gates and
  - $\blacksquare$  (J 1) **K-bit adders** to produce a product of (J + K) bits.



- 5
- $\blacksquare$  B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub> by A<sub>2</sub>A<sub>1</sub>A<sub>0</sub>
- Since K = 4 and J = 3, we need 12 AND gates and two 4-bit adders to produce a product of seven bits



- The comparison of two numbers is an operation that determines whether one number is greater than, less than, or equal to the other number.
- Magnitude comparator is a combinational circuit that compares two numbers A and B and determines their relative magnitudes.
  - **■** A>B
  - **■** A=B
  - A<B</p>

Magnitude Comparator

| А | В | A>B | A=B | A <b< th=""></b<> |
|---|---|-----|-----|-------------------|
| 0 | 0 | 0   | 1   | 0                 |
| 0 | 1 | 0   | 0   | 1                 |
| 1 | 0 | 1   | 0   | 0                 |
| 1 | 1 | 0   | 1   | 0                 |

What about more than one bit?



# Magnitude Comparator

- The circuit for comparing two *n*-bit numbers has  $2^{2n}$  entries in the truth table and becomes too cumbersome, even with n = 3.
- $\rightarrow$  A=B ( X-NOR Solution)

$$x_i = A_i B_i + A'_i B'_i$$
 for  $i = 0, 1, 2, 3$   
 $(A = B) = x_3 x_2 x_1 x_0$ 

■ To determine whether A is greater or less than B, we inspect the relative magnitudes of pairs of significant digits, starting from the most significant position.

# Magnitude Comparator

Greater than and less than

$$(A > B) = A_3 B_3' + x_3 A_2 B_2' + x_3 x_2 A_1 B_1' + x_3 x_2 x_1 A_0 B_0'$$
  

$$(A < B) = A_3' B_3 + x_3 A_2' B_2 + x_3 x_2 A_1' B_1' + x_3 x_2 x_1 A' n_0 B_0'$$

The symbols A > B and A < B are binary output variables that are equal to 1 when A > B and A < B, respectively.</p>





- A binary code of n bits is capable of representing up to 2<sup>n</sup> distinct elements of coded information.
- A decoder is a combinational circuit that converts binary information from *n* input lines to a maximum of 2<sup>n</sup> unique output lines.
- If the n-bit coded information has **unused** combinations, the decoder may have fewer than  $2^n$  outputs.
- Their purpose is to generate the 2<sup>n</sup> (or fewer) minterms of n input variables
- The name decoder is also used in conjunction with other code converters, such as a BCD-to-seven-segment decoder

12

 A particular application of this decoder is binary-tooctal conversion



# Three-to-eight-line decoder

**Table 4.6** *Truth Table of a Three-to-Eight-Line Decoder* 

| Inputs |   |   |   |                             |                | Ou    | tputs |       |                |       |
|--------|---|---|---|-----------------------------|----------------|-------|-------|-------|----------------|-------|
| X      | y | Z | D | <sub>0</sub> D <sub>1</sub> | D <sub>2</sub> | $D_3$ | $D_4$ | $D_5$ | D <sub>6</sub> | $D_7$ |
| 0      | 0 | 0 | 1 | 0                           | 0              | 0     | 0     | 0     | 0              | 0     |
| 0      | 0 | 1 | 0 | 1                           | 0              | 0     | 0     | 0     | 0              | 0     |
| 0      | 1 | 0 | 0 | 0                           | 1              | 0     | 0     | 0     | 0              | 0     |
| 0      | 1 | 1 | 0 | 0                           | 0              | 1     | 0     | 0     | 0              | 0     |
| 1      | 0 | 0 | 0 | 0                           | 0              | 0     | 1     | 0     | 0              | 0     |
| 1      | 0 | 1 | 0 | 0                           | 0              | 0     | 0     | 1     | 0              | 0     |
| 1      | 1 | 0 | 0 | 0                           | 0              | 0     | 0     | 0     | 1              | 0     |
| 1      | 1 | 1 | 0 | 0                           | 0              | 0     | 0     | 0     | 0              | 1     |





| E           | A      | В      | $D_0$       | $D_1$       | $D_2$       | $D_3$       |
|-------------|--------|--------|-------------|-------------|-------------|-------------|
| 1 0         | X<br>0 | X<br>0 | 1 0         | 1 1         | 1 1 1       | 1<br>1<br>1 |
| 0<br>0<br>0 | 1<br>1 | 0<br>1 | 1<br>1<br>1 | 0<br>1<br>1 | 1<br>0<br>1 | 1<br>1<br>0 |

Copyright ©2013 Pearson Education, publishing as Prentice Hall

- (b) Truth table
- A decoder with enable input can function as a demultiplexer
- Demultiplexer: A circuit that receives information from a single line and directs it to one of 2<sup>n</sup> possible output lines.

Decoders with enable inputs can be connected together to form a larger decoder circuit.



# Combinational Logic Implementation

Since any Boolean function can be expressed in sum-of-minterms form, a decoder that generates the minterms of the function, together with an external OR gate that forms their logical sum, provides a hardware implementation of the function.

**Table 4.4** *Full Adder* 

| - |   |   |   |   |   |
|---|---|---|---|---|---|
|   | X | y | Z | С | S |
|   | 0 | 0 | 0 | 0 | 0 |
|   | 0 | 0 | 1 | 0 | 1 |
|   | 0 | 1 | 0 | 0 | 1 |
|   | 0 | 1 | 1 | 1 | 0 |
|   | 1 | 0 | 0 | 0 | 1 |
|   | 1 | 0 | 1 | 1 | 0 |
|   | 1 | 1 | 0 | 1 | 0 |
|   | 1 | 1 | 1 | 1 | 1 |
|   |   |   |   |   |   |

## Implementation of a full adder with a

decoder

 $S(x, y, z) = \Sigma(1, 2, 4, 7)$ 

- The OR gate for output S forms the logical sum of minterms 1,
- 2, 4, and 7. The OR gate for output C forms the logical sum of minterms 3, 5, 6, and 7.



Copyright ©2013 Pearson Education, publishing as Prentice Hall

# Implementation of a full adder with a decoder

- A function with a long list of minterms requires an OR gate with a large number of inputs.
- A function having a list of k minterms can be expressed in its complemented form F with 2<sup>n</sup> - k minterms. If the number of minterms in the function is greater than 2<sup>n</sup>/2 then F can be expressed with fewer minterms.
- In such a case, it is advantageous to use a **NOR gate** to sum the minterms of *F*.

- An encoder is a digital circuit that performs the inverse operation of a decoder
- $\rightarrow$  An encoder has  $2^n$  (or fewer) input lines and n output lines
- The output lines, as an aggregate, generate the binary code corresponding to the input value

20

The encoder can be implemented with three OR gates

$$z = D_1 + D_3 + D_5 + D_7$$
  
 $y = D_2 + D_3 + D_6 + D_7$   
 $x = D_4 + D_5 + D_6 + D_7$ 

# **Table 4.7** *Truth Table of an Octal-to-Binary Encoder*

|       |       |       | Inp   | uts   |       |       |                       |   | utput | :S |
|-------|-------|-------|-------|-------|-------|-------|-----------------------|---|-------|----|
| $D_0$ | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | <b>D</b> <sub>7</sub> | X | y     | Z  |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0                     | 0 | 0     | 0  |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0                     | 0 | 0     | 1  |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0                     | 0 | 1     | 0  |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0                     | 0 | 1     | 1  |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0                     | 1 | 0     | 0  |
| 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0                     | 1 | 0     | 1  |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0                     | 1 | 1     | 0  |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     | 1 | 1     | 1  |

- The problem:
  - It has the limitation that only one input can be active at any given time
  - If two inputs are active simultaneously, the output produces an undefined combination
- For example, if  $D_3$  and  $D_6$  are 1 simultaneously, the output of the encoder will be 111 because all three outputs are equal to 1
- The output 111 does not represent either binary 3 or binary 6
- To resolve this ambiguity, encoder circuits must establish an input priority to ensure that only one input is encoded
- If both  $D_3$  and  $D_6$  are 1 at the same time, the output will be 110 because  $D_6$  has higher priority than  $D_3$
- Another ambiguity in the octal-to-binary encoder is that an output with all 0's is generated when all the inputs are 0; but this output is the same as when  $D_0$  is equal to 1.

# Priority Encoder

- If two or more inputs are equal to 1 at the same time, the input having the highest priority will take precedence.
- ► Valid bit indicator is set to 1 when one or more inputs are equal to 1. If all inputs are 0, there is no valid input and V is equal to 0.
- Input D<sub>3</sub> has the highest priority, so, regardless of the values of the other inputs, when this input is 1, the output for xy is 11 (binary 3)

**Table 4.8** *Truth Table of a Priority Encoder* 

|              | Inp                   | uts            |       | utput | S |   |
|--------------|-----------------------|----------------|-------|-------|---|---|
| $D_0$        | <b>D</b> <sub>1</sub> | D <sub>2</sub> | $D_3$ | X     | y | V |
| 0            | 0                     | 0              | 0     | X     | X | 0 |
| 1            | 0                     | 0              | 0     | 0     | 0 | 1 |
| $\mathbf{X}$ | 1                     | 0              | 0     | 0     | 1 | 1 |
| $\mathbf{X}$ | $\mathbf{X}$          | 1              | 0     | 1     | 0 | 1 |
| X            | X                     | X              | 1     | 1     | 1 | 1 |

Copyright ©2012 Pearson Education, publishing as Prentice Hal

23

**Table 4.8** *Truth Table of a Priority Encoder* 

|       | Inp   | uts            | 0              | utput | S |   |
|-------|-------|----------------|----------------|-------|---|---|
| $D_0$ | $D_1$ | D <sub>2</sub> | D <sub>3</sub> | х     | y | V |
| 0     | 0     | 0              | 0              | X     | X | 0 |
| 1     | 0     | 0              | 0              | 0     | 0 | 1 |
| X     | 1     | 0              | 0              | 0     | 1 | 1 |
| X     | X     | 1              | 0              | 1     | 0 | 1 |
| X     | X     | X              | 1              | 1     | 1 | 1 |





| ur-bit Priority Encoder | Table 4.8 Truth Table of a Priority Encoder |
|-------------------------|---------------------------------------------|
| ,                       | Immedia                                     |

|       | Inp                   | uts            | 0              | utput | S |   |
|-------|-----------------------|----------------|----------------|-------|---|---|
| $D_0$ | <b>D</b> <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | х     | y | V |
| 0     | 0                     | 0              | 0              | X     | X | 0 |
| 1     | 0                     | 0              | 0              | 0     | 0 | 1 |
| X     | 1                     | 0              | 0              | 0     | 1 | 1 |
| X     | X                     | 1              | 0              | 1     | 0 | 1 |
| X     | X                     | X              | 1              | 1     | 1 | 1 |

Copyright ©2013 Pearson Education, publishing as Prentice Hall

 $x = D_2 + D_3$ 

 $y = D_3 + D_1 D_2'$ 

 $V = D_0 + D_1 + D_2 + D_3$ 

# 4.11 Multiplexers

- A multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line.
- There are 2<sup>n</sup> input lines and n selection lines whose bit combinations determine which input is selected
- The multiplexer acts like an electronic switch that selects one of the sources
- The multiplexer is often labeled "MUX" in block diagrams
- A multiplexer is also called a data selector

A two-to-one-line multiplexer connects one of two 1-bit sources to a common destination



# Four-to-one line multiplexer

27



(b) Function table

 $S_0$ 

(a) Truth table

# Implementing a Boolean function with a multiplexer $F(x, y, z) = \Sigma(1, 2, 6, 7)$

(b) Multiplexer implementation

When the input to a combinational logic circuit changes, unwanted switching transients may appear on the output.

These transients occur when different paths from input to output have different propagation delays.



- When analyzing combinational logic circuits for hazards we will consider the case where only one input changes at a time.
- Under this condition, a <u>static 1-hazard</u> occurs when the input change causes one product term (in a SOP expression) to transition from 1 to 0 and another product term to transition from 0 to 1.
- Both product terms can be transiently 0, resulting in the static 1-hazard.

- There is a delay for the logic gates
- When they dd up together they create timing hazards.
  - $t_{pLH} = low-to-high, t_{pHL} = high-to-low$
- Three types exist
  - Static-0: Expected 0 but received 1 for a short period of time. It occurs in POS circiuits
  - Static 1: Expected 1 received 0 for a short period of time. It occurs on POS circuits.
  - **Dynamic:** Multiple changses in the output before stable.





- Under the same condition, a <u>static 0-hazard</u> occurs when the input change causes one sum term (in a POS expression) to transition from 0 to 1 and another sum term to transition from 1 to 0.
- Both sum terms can be transiently 1, resulting in the static 0-hazard.

# Detecting Static 1-Hazards

We can detect hazards in a two-level AND-OR circuit using the following procedure:

- 1. Write down the sum-of-products expression for the circuit.
- 2. Plot each term on the map and loop it.
- 3. If any two adjacent 1's are not covered by the same loop, a 1-hazard exists for the transition between the two 1's. For an n-variable map, this transition occurs when one variable changes and the other n-1 variables are held constant.

# Detecting Static 1-Hazards



# Removing Static 1-Hazards



# Detecting Static 0-Hazards

We can detect hazards in a two-level OR-AND circuit using the following procedure:

- 1. Write down the product-of-sums expression for the circuit.
- 2. Plot each sum term on the map and loop the zeros.
- 3. If any two adjacent 0's are not covered by the same loop, a 0-hazard exists for the transition between the two 0's. For an n-variable map, this transition occurs when one variable changes and the other n-1 variables are held constant.

# Detecting Static 0-Hazards



# Removing Static 0-Hazards



# Sample question

(inverter) 5ns, AND gate 10ns. initially X=0. X became 1 for 80ns then become 0

Draw a timing diagram showing changes in X, Y ve Z



41

Draw an empty timing diagram

Show the formula for the circuit

$$ightharpoonup Z = XY = XZ'$$

- Show initial values of X and Y
- Draw the rest considering the gate delays

(inverter) 5ns, AND gate 10ns delay.
Initially X=0 Y=1
What if for 80ns X=1 and then
becomes 0





